

## **Assignment 2**

# Design the following circuits using Verilog and create a randomized testbench.

Q1: Design this 3x8 Decoder with enable signal.



#### Truth Table:

| Enable | INPUTS         |                |    | Outputs |            |                       |                       |                       |                |                |    |
|--------|----------------|----------------|----|---------|------------|-----------------------|-----------------------|-----------------------|----------------|----------------|----|
| E      | A <sub>2</sub> | A <sub>1</sub> | Ao | Y7      | <b>Y</b> 6 | <b>Y</b> <sub>5</sub> | <b>Y</b> <sub>4</sub> | <b>Y</b> <sub>3</sub> | Y <sub>2</sub> | Y <sub>1</sub> | Yo |
| 0      | ×              | ×              | ×  | 0       | 0          | 0                     | 0                     | 0                     | 0              | 0              | 0  |
| 1      | 0              | 0              | 0  | 0       | 0          | 0                     | 0                     | 0                     | 0              | 0              | 1  |
| 1      | 0              | 0              | 1  | 0       | 0          | 0                     | 0                     | 0                     | 0              | 1              | o  |
| 1      | 0              | 1              | 0  | 0       | 0          | 0                     | 0                     | 0                     | 1              | 0              | 0  |
| 1      | 0              | 1              | 1  | 0       | 0          | 0                     | 0                     | 1                     | 0              | 0              | 0  |
| 1      | 1              | 0              | 0  | 0       | 0          | 0                     | 1                     | 0                     | 0              | 0              | 0  |
| 1      | 1              | 0              | 1  | 0       | 0          | 1                     | 0                     | 0                     | 0              | 0              | 0  |
| 1      | 1              | 1              | 0  | 0       | 1          | 0                     | 0                     | 0                     | 0              | 0              | 0  |
| 1      | 1              | 1              | 1  | 1       | 0          | 0                     | 0                     | 0                     | 0              | 0              | 0  |



Q2: We have 3 inputs N bits (A , B , C) and 2N bits output (out1, out 2) since N is a parameter = 5.





# You should compare between three numbers and assign the outputs according to the table below:

| Input                | Out1                  | Out2                   |
|----------------------|-----------------------|------------------------|
|                      |                       |                        |
| The largest number   | Sign extension of the | Concatenate of the     |
| And two other inputs | largest number        | other two inputs       |
| The three inputs are | Out1= shift left by 2 | Out2= shift right by 2 |
| equal                | of the input          | of the input           |
| Default              | Out1=0                | Out2=0                 |

<u>Do we really want to write default case or we covered all possibilities? Justify your answer.</u>

### Sign extension explanation:

Is to check the most significant bit if it was zero then the output will be extended by zeros else will be extended by ones.

